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SYSTEM AND METHOD FOR ADAPTING INFORMATION CONTENT FOR 

AN ELECTRONIC DEVICE 

REFERENCE TO RELATED APPLICATIONS 

This application claims priority to United States provisional application Serial No. 
60/199,858 filed on April 26, 2000. 

FIELD OF THE INVENTION 
This present invention relates generally to the field of network communications. 
More specifically, it relates to a system and method for accessing, adapting, and 
presenting information content for electronic devices. 

BACKGROUND OF THE INVENTION 
Today, an abundant amount of meaningful and feature rich information content is 
truly at one's fingertips. Currently, using a personal computer (PC) and PC-based 
browser, one can find information online regarding just about anything they desire. One 
can communicate with people on the other side of the U.S. or world, set up a 
teleconference call, tap into the resources of other computers across the earth, search 
through the world's finest libraries, and visit images from the world's most remarkable 
museums. One can even use the PC-based browser to watch videos and listen to their 
favorite music, monitor the financial markets, find the local weather forecast, go 
shopping, download application software, and so on. Currently, all of this can be done 
with a personal computer and a PC-based browser that is tapped into a feature rich 
network of computers such as the Internet, Intranet, or Extranet. 

At the same time, the field of communications, and more specifically wireless 
telecommunications, is currently undergoing a radical expansion. This technological 
expansion allows an electronic device, such as mobile personal digital assistant (PDA), 
cellular phone, pager, and other electronic devices to connect to the same information 
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sources, such as a web server or database, as one could with the PC and a PC-based 
browser. 

Unfortunately, this feature rich information content was developed for a standard 
PC-based browser, not a mobile or portable electronic device that might be limited in 
5 memory, screen size, bandwidth, navigation capabilities, power consumption, processing 
power, etc. For example, an electronic device, such as portable PDA, with a small screen 
size may be inappropriate to display the same information content originally intended for 
a PC-based browser, and viewed on a 15-inch or greater size display monitor. 
Consequently, the PDA can not be able to faithfully access and display information 
10 content as it was originally intended to be viewed. Therefore, it would be desirable to 
access, organize, and navigate information content including applications. 

In another example, a mobile or wireless device with only low bandwidth 
capability may be unable to view information content intended for only high bandwidth 
applications. Parameters such as the mobile or wireless device's network connection, 
15 memory capacity, power restrictions, or other limitations of the device may require 
customization of information content that is delivered to or from the device. Therefore, it 
would be desirable to streamline the information content such that the desired content is 
received and presented at the mobile device as it was intended to be viewed. 

In yet another example, current electronic devices cannot take full advantage of 
20 dynamically generated content and interactive Web sites that are typically hosted on 
today's Web servers. According to this example, scripting languages like JavaScript or 
Jscript allow a user on a PC-based browser to interact with markup language such as 
Hypertext Markup Language (HTML) source code, thus enabling the use of dynamic 
content. However, it would be desirable for a portable electronic device, although 
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possibly having limited abilities, to also utilize the modern and current scripting 
languages. 

Currently, information content is sent to the device, but often in a format that the 
appliance, user, or network cannot conveniently accommodate, which produces 
5 undesirable results. For example, the data content might be unreadable on the display, 
displayed in an unorganized fashion, be too voluminous or bandwidth intensive to be 
received or displayed, and so on. 

Thus, it would be desirable to transparently extend internet and intranet 
technologies to an electronic device over a wired or wireless domain. 
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SUMMARY OF THE INVENTION 

A system and method is provided that enables electronic devices with limited 
hardware or network capability to successfully access the same feature rich information 
content as full featured PC-based browsers with a large display screen, extensive user 
5 input facilities (e.g., mouse, keyboard, etc), high CPU power, large memory, reliable 
network connections, a reliable power supply, and so on. 

In an aspect of the present embodiment, the system enables an electronic device to 
access a number of different information sources including, but not limited to, marked up 
content like HTML, XML, WML, voice and multimedia. In the exemplary embodiment, 
10 a script execution engine is utilized to support scripting technologies such as JavaScript 
that dynamically generate content. 

According to another aspect of the present embodiment, a distributed browser 
includes separable components, a server browser and a client browser, that enable an 
electronic device with a small display to efficiently access information content. In the 
15 exemplary embodiment, the server browser and the client browser work together to 
access the information content by separating functionality between the browsers, 
irrespective of the component's location. Preferably, the functionality applied to optimize 
information content access, arrangement, transmission, and navigation can be performed 
by the server browser rather than the client browser hosted on the portable or mobile 
20 device. 

According to another aspect of the present embodiment, a QDOM converts data 

content into a document object tree represented by a mutable object having an array 

structure. Based on the nodes of the object tree, the QDOM generates an array of 

primitive data types for efficiently developing an optimized standard structure for use by 

25 a normalizer or other processing modules. In the manner, the QDOM extends the World 
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Wide Web Consortium (W3C) DOM interface definition to an efficient model that 
provides high speed parsing, storage, and access while minimizing memory resource 
requirements. 

In another aspect of the present embodiment, a normalizer adaptively tailors and 
5 folderizes markup based information content to accommodate an electronic device's 
particular software, hardware, and network characteristics. In the exemplary 
embodiment, the normalizer organizes any markup based information content into folders 
of interest. The user of the electronic device can then further explore the folders of 
interest as desired. 

10 In yet another aspect of the present embodiment, metatags embedded in a markup 

language at the information source can provide instructions to the normalizer to take 
appropriate actions.. Use of metatags can allow customization of original information 
content if a modified outcome is desired at the electronic device. In the exemplary 
embodiment, the metatags provide instruction to an automatic normalizer including, but 

15 not limited to, direct output of information content without normalization, the promotion 
of content into or out of folders, and dropping or filtering information content from the 
serialized output to an electronic device. 

In another aspect of the present embodiment, pattenwnatching templates are 
utilized to normalize the presentation of accessed information content. In the exemplary 

20 embodiment, a template normalizer utilizes regular expression pattern-matching to 
impose a template over a document and attempts to match the template to the document. 

In another aspect of the present invention, an event translator provides additional 
compatibility with commercially available client browsers or end user applications that 
employ standardized protocols. In the exemplary embodiment, the event translator can be 



02067 13SA2 I > 



WO 02/087135 PCT/US02/I3173 

utilized on the server browser or the client browser to provide compatibility with 
standard client browsers. 

In an aspect of the present embodiment, a serializer dynamically formats 
normalized content to a form that is optimized for a particular electronic device. The 
5 serialized output can be formatted to suit industry standard browsers, or targeted to an 
electronic device using the client side browser. 

The present embodiments allow for electronic devices with limited hardware 
capability to access, on the fly, feature rich static and dynamic content, and applications. 
The server browser enables a client browser that utilizes a particular markup language to 
10 access information content that is of any type of markup language or technology. The 
distributed browser minimizes the functionality required on the device and implements 
the CPU and memory intensive functions on a server in the network, thus allowing 
wireless devices, with intermittent, limited connectivity, processing power capability etc. 
to provide a similar experience achieved with a desktop PC. 
15 Multiple components including a serializer, normalizer, client browser, and/or the 

event translator work in conjunction with each other to convert user events within one 
markup domain into another markup domain while staying in the transaction to translate 
the meaning of the interaction appropriately. Thus, for example, user events such as ; 
scrolling, clicking, voice commands interact with the QDOM to result in a change in 
20 presentation of the content. 

Additionally, the present embodiments provide significantly higher speed and an 
efficient use of network bandwidth as desired information content can be cached on the 
server browser and on the client browser, if so desired, to enable quick access to the 
desired portions of the information content. 
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The present embodiments also provide for server browser-centric access to user 
profile and client browser state inforaiation (such as cookies), thereby facilitating the use 
of multiple devices by a single user. 

The present embodiments provide a number of advantages and applications as will 
be more apparent to those skilled in the art. The exemplary embodiments utilize 
distributed architecture for adaptively tailoring information content to electronic device's 
hardware and network characteristics. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a high-level diagram illustrating an exemplary system for accessing, 
adapting, and presenting information content to electronic devices; 

FIG. 2 is a diagram further illustrating the server browser of FIG. 1; 
5 FIG. 3 is a diagram further illustrating the event translator of FIG. 1; 

FIG. 4 is a diagram further illustrating the client browser of FIG. 1; 

FIG. 5 is a diagram illustrating an events message utilized in the exemplary 
system of FIG. 1; 

FIG. 6 is a diagram illustrating a transmission ACK7NAK message utilized in the 
10 exemplary system of FIG. 1; 

FIG. 7 is a diagram illustrating a security handshake request/response and 
ACK/NAK message utilized in the exemplary system of FIG. 1 ; 

FIG. 8 is a diagram illustrating an exemplary process of the QDOM of FIG. 1; 

FIG. 9 is a diagram further illustrating the process of the QDOM of FIG. 8; 
15 FIG. 10 is a diagram illustrating the process of the normalizer of FIG. 1; 

FIG. 1 1 is a diagram further illustrating the process of FIG. 10; and 

FIG. 12 is a diagram showing an exemplary conversion of output from the system 
of FIG 1. 
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DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS 

FIG. 1 shows a high-level block diagram illustrating an exemplary system 10b for 
accessing and adapting feature rich information content for presentation on an electronic 
device 104. The accessed and adapted information content is transmitted between an 
5 information source 102 and the electronic device 104. 

The information source 102 includes any type of device such as a web server, 
application server, database or other backend system, or any interface to an information 
provider. Preferably, the information source 102 provides information content expressed 
in a markup language, such as those markup languages known in the art including 

10 Hypertext Markup Language (HTML), Extensible Markup Language (XML) with or 
without Extensible Style Sheets (XSL), VoiceXML, Extensible Hypertext Markup 
Language (XHTML), or Wireless Markup Language (WML). Furthermore, the 
information content can store images, video, audio information. Preferably, the 
information source 102 can be accessed through an information access network 106 such 

15 as a local area network (LAN) or wide area network (WAN). 

The electronic device 104 includes any type of device such as a personal computer 
(PC), wireless telephone, personal digital assistant (PDA), hand-held computer, network 
appliance, and a wide variety of other types of electronic devices that might have 
navigational capability (e.g., keyboard, touch screen, mouse, etc.) and an optional display 

20 for viewing downloaded information content. Furthermore, the electronic device 104 can 
also include a device such as a set-top box, internet access appliance, infra-red remote 
control used with a set-top box, and so forth. Moreover, the electronic device 104 can 
include any type of device that has the capability to utilize speech synthesis markups such 
as W3C (www.w3.org) Voice Extensible Markup Language (VoiceXML). 
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Information content from the information source 102 is preferably retrieved and 
tailored for use on the electronic device 104 by a distributed browser 10S. The distributed 
browser 108 is generally made up of a server browser 110 and a client browser 112. By 
utilizing the distributed browser 108, smaller electronic devices with limited hardware 
5 capability can access feature rich information or data. Moreover, the distributed browser 
10S allows for efficient use of the communications network 114 bandwidth. Of course, 
electronic devices with high processing power, fast network connection, and large 
memory can also use the present embodiments. 

In the exemplary embodiment, the server browser 110 and the client browser 112 

10 are hosted on separate platforms. For example, the server browser 110 might be hosted 
on a back-end server, and the client browser 112 might be hosted on the electronic device 
104. However, it should be understood that the server browser 110 and client browser 
1 12 can be hosted on the same platform such as on an electronic device, especially if the 
platform or electronic device has the appropriate hardware and network capabilities. 

15 The server browser 110 can access information content at the information source 

102 via the information access network 106. Tn the exemplary embodiment, the server 
browser 110 operates as a client of the information source 102. For example, using a 
known suite of communications protocols such as Transmission Control Protocol/Internet 
Protocol (TCP/IP), the server browser 110 can issue a Hypertext Transfer Protocol 

20 (HTTP) request to the information source 102 over the information access network 106. 
By utilizing HTTP requests, such as is known in the art, the server browser 110 can 
access information content, including applications, static and dynamic content, at the 
information source 102. Dynamic content can include script codes such as JavaScript, 
developed by Netscape (www.netscape.com), and Jscript, developed by Microsoft 

25 (www.microsoft.com). 

10 
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Preferably, communications between the client and server browsers 112 and 110, 
respectively, are via a defined application protocol implemented on top of a wired or 
wireless transport layer depending on the nature of the electronic device 104 and 
communications network 1 14. 
5 Therefore, the communications network 114 might include a wired network such 

as those that utilize Ethernet or similarly IEEE S02.3 protocols. The communications 
network 114 might also include a wireless network such as a local area wireless network 
(LAWN) or wireless local area network (WLAN). Moreover, the communications 
network 114 might include wireless networks that utilize other known protocols and 

10 technologies such as Bluetooth, wireless application protocol (WAP), time division 
multiple access (TDMA), or code division multiple access (CDMA). Furthermore, the 
communications network 114 is not limited to. terrestrial networks, but can utilize other 
forms of transmission, as is known in the art, such as a satellite connection. 

To provide an exemplary illustration, assume that a PDA hosts a client browser, a 

15 PC hosts a server browser, and the PDA and PC are both connected to an Ethernet 
network. Then, the client browser and the server browser could perform information 
transactions over the Ethernet network. Such transactions would utilize Ethernet or 
similarly IEEE 802.3 protocols. Nevertheless, in this example, the client and server 
browsers communicate over a wired network. 

20 In another example, assume that an internet-enabled refrigerator hosts a client 

browser, a set-top box hosts a server browser, and both could perform information 
transactions over a Bluetooth or IEEE 802.11 wireless LAN. Then, according to this 
example, the client and server browsers are communicating over a wireless network. 

Referring again to FIG. 1, a commercially available or standard client browser 140 

25 can also be supported. Preferably, an event translator 136 is used to convert a 
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request/response protocol, such as an HTTP request, from the standard client browser 
140 (e.g., WML, XHTML, cHTML, etc.) to an event that the server browser 110 
recognizes. Preferably, the translation process includes event information, content 
information, and the context of the event such that transactions between the standard 
5 client browser 140 and the information source 102 (e.g. HTML fomi submission) are 
preserved. Therefore, by using the event translator 136, the server browser 110 can 
provide an interface to any end user application with a known protocol. Thus, for 
example, an electronic device 104 can utilize the client browser 112 or standard client 
browser 140, or both at the same time, if so desired. 
10 The server browser 110 can be hosted on any platform with sufficient hardware 

capability for performing tasks by the server browser 110 described herein. Such 
platforms can include but are certainly not limited to desktop or laptop PCs, servers, 
computer clusters, or embedded devices. It should also be understood that the server 
browser 110 can also be hosted on the electronic device 104, especially if the electronic 
15 device has the hardware and network connection capability. 
! According to the exemplary embodiment, the server browser 110 can authenticate 

j itself with the information source 102, facilitate the request of the information using a 

| protocol acceptable to the information source 102 (e.g., an HTTP request for a web 

; server), provide secure transactions with the information source 102, provide secure 

j 20 transactions with the client browser 112, execute embedded scripts or code segments, and 

j resolve necessary external references (e.g., request HTML frames or script sources) to 

i 

i 

j complete the information model. Preferably, the server browser 110 also includes 

information content caching and data pre-fetch for performance gain. 

Furthermore, the server browser 110 can perform information content 

25 transformations or apply device specific style sheets to aid in presentation (e.g., display or 

12 
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voice) and navigation (e.g., keyboard, touch screen, or scrolling), and perform content 
grouping for electronic devices that accepts data in limited quantities. 

To deliver these capabilities, the server browser 110 preferably contains the 
modules including user agent 1 10, cookie handler 1 12, QDOM 1 16, script executor 120, 
5 normalizer 124, serializer 128, and connectivity 132, each described below. A session 
manager 108 is also included to manage the session between the client browser 112 and 
the server browser 1 10. Similarly, the session manager 108 can also manage the session 
between the standard client browser 24 and the server browser 110. 

FIG. 2 is a diagram further illustrating the server browser of FIG. 1 . The server 
10 browser utilizes a user agent 110 for accessing information at the information source 102. 
Preferably, the user agent 110 has the functionality of a traditional PC browser (e.g., 
Netscape Navigator, Internet Explorer, and so forth) as well as extended functionality, 
described below, due to the distributed nature of the electronic device 104. To access the 
appropriate information content at the information source 102, the user agent 110 
1 5 communicates the requested resource identifier to the information source 1 02. 

For example, the user agent 110 might "transmit an HTTP request to a remote web 
server that hosts yahoo.com. According to this example, the user agent 110 would 
transmit a resource identifier to request a specific web page or ask the remote web server 
to perform a database query. The request including the resource identifier is broken into 
20 HTTP packets and the packets are sent across the Internet's TCP/IP communications 
infrastructure to the remote web server. The resource identifier then enables the host 
computer to locate the requested page at yahoo.com and return the information content to 
the user agent 110. 

In addition to transmitting the resource identifier, the user agent 110 might inform 

25 the information source 102 of the client browser 112 type, electronic device 104 

13 
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capabilities, and user preferences in the request headers and receives information 
identifying the properties of the data received (such as the content type, length and 
encoding) in the response headers. The headers that are sent back and forth between the 
information source 102 and the server browser 110 may also contain one or more cookies 
5 stored at the server browser 1 10 on behalf of the client browser 112. 

Preferably, the user agent 110 conforms to the broader industry definition of the 
term as a component of the server browser 110 that acts on behalf of the electronic device 
104 to request information from an information source 102. The requested information 
content can be from any information source including a web server as described above, 

10 but is not restricted to a web server. Other sources of information content might include 
an email server, Instant Messaging server, database or other storage of information. 
Additionally, the means through which the user agent 110 communicates with the 
information source 102 includes the HTTP protocol as described above, but of course, is 
not limited to that protocol. 

15 Information content might also use XML information content and XSL style 

sheets instead of HTML as the preferred internet/intranet information content format. By 
using XML information content and an XSL style sheet, it can provide a clear separation 
of data and presentation. The XSL style sheet is applied to the XML information content 
by an XSLT engine to present the information content to an electronic device 104. 

20 The XSL style sheet is applied to the XML information content at the information 

source 102, but preferably the client browser 112 can also apply the XSL style sheet to 

the XML information content. In this case, the server browser 110 preferably employs an 

XSLT engine to apply the XSL style sheet to the XML data before normalizing to 

produce content. One such example would be a WML client browser used to request an 

25 XML + XSL combination that produces XHTML. 

14 
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Alternatively, the information content author may choose to use the original 
XML and apply templates and/or wireless markup instead of or in combination with XSL 
style sheets. 

In addition to providing normalizer functionality, the system can also use 
5 templates and meta-tag markup to alter the original information content to better suit an 
end user application for which it was not originally designed. This can be achieved 
through the addition, removal or substitution of sections of content, tags and attributes 
(separately or together) in the markup, described more below. 

Information content might also use VoiceXML (www.voicexml.org) which is an 
10 XML based language for specifying voice dialogs, including audio prompts and text-to- 
speech (TTS) for output and touch-tone keys (DTMF) as well as automatic speech 
recognition (ASR) for input. VoiceXML technology enables consolidation of voice and 
web applications. For example, it can be used with voice-only devices to access a voice 
portal, or used to facilitate multi-modal (graphical and voice) dialogs to VoiceXML 
15 enabled client browsers). 

Preferably, the system (100 in FIG. 1) via the user manager 110 has the ability to 
read and process VoiceXML markup as well as convert from one markup (from WML for 
instance) to VoiceXML format. In addition, templates and/or wireless markup can be 
used to specify which parts of a web page are to be audible (i.e. converted to VoiceXML) 
20 and which are to be rendered visually by the browser. The server can interact with a 
VoiceXML gateway (much in the same way as it does with the WML gateway) to 
facilitate the VoiceXML based services. 

Location based services might also prove to be very popular in this industry as 

they are well suited to mobile applications. Preferably, the server browser 110 via the 

25 user agent 110 has the ability to interact with the network entity supplying the location 

15 
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information via a defined protocol. The current coordinates of the electronic device 
accessing the network are preferably sent in the request headers to the content (web) 
server and/or be accessible via session cookies so that the device can easily utilize this 
location information. This functionality enables useful applications such as a restaurant 

5 locator that lists restaurants within a few miles of the user's current location. 

Referring back to FIG. 1, the server browser 110 contains a cookie handler 112. 
Cookies provide a means of personalizing the information content that is retrieved by the 
user agent 110 on behalf of the user of the electronic device 104. Preferably, the cookie 
handler 112 supports session and persistent cookies. Session cookies are valid for the 

10 current user's session and persistent cookies can expire after a pre-determined time 
specified in the cookie or be permanent. An added benefit to server side cookie 
processing is that the user is provided access to his or her cookies from multiple 
electronic devices and the user's cookies are not lost when the user changes electronic 
devices. 

15 Referring back to FIG. 2, the user agent 110 translates the requested data content, 

if necessary, into a recognizable markup language for further processing. The markup 
language may be in the format of XML, WML, HTML, or any other markup language or 
technology (e.g., video, audio, image) that incorporates the features used by the present 
embodiments. 

20 The translated information is then organized into a logically structured format for 

further processing by the QDOM 116. The QDOM 116 efficiently constructs a nodal 

structure. The use of the QDOM 116 enables a standard structured interface to the 

retrieved content that can be utilized by all modules of the server browser 110. The 

QDOM 116 can effectively and efficiently store the information content in a standardized 

25 structure for use by the normalizer, more described below. 
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Referring back to FIG. 1, the server browser 110 has script executor 120 for 
assisting the QDOM 1 16 in interpreting embedded script code in the information content 
received from the infonnation source 102. The script executor 120 is preferably capable 
of supporting the European Computer Manufactures Association standard (ECMAScript 
5 revision 3), which is most prevalent in the industry, but may also be capable of handling 
other scripting languages, known in the art, such as JavaScript, Jscript (Microsoft's 
extending implementation of ECMAScript), Visual Basic Script (VBScript), or 
WMLScript. The script executor 120 enables programmatic access to the QDOM 116 
representation of the document. 

10 This extension to the QDOM 116 can allow executed script code to modify the 

resultant document that is sent to the client browser 112, thus enabling dynamic content 
generation via scripting. Script executor 120 can also allow programmatic access to the 
cookies for a particular user, giving the content author the ability to create, modify or 
retrieve cookies associated with a given resource via script code. To interact with the 

15 user, communications between the script executor 120 and the client browser 1 12 is done 
via script events that are part of the application protocol between the server browser 110 
and the client browser 1 12. 

Referring again to FIG. 2, data content that has been transformed into a DOM tree 
is then forwarded from the QDOM 116 to the normalizer 124. Preferably, the normalizer 

20 124 sends the DOM tree first to a template normalizer. If the template normalizer is 
unsuccessful at normalization, the DOM tree is then forwarded to an automatic 
normalizer where the data is normalized and then forwarded to the serializer 128 to be 
sent to the electronic device 104 via the connectivity manager 132, further described 
below. 

17 

BNSOOCta <WO_020B7135A2„I_> 



WO 02/087135 PCT/US02/131 73 

The serializer 128 utilizes the normalized tree as input and produces a media 
stream targeted for a specific electronic device 104. Applying a style sheet or formatting 
rules to the DOM tree outputs a document (e.g., an XML document) that will be streamed 
to the electronic device 104. Preferably, the formatting rules are electronic device 104 
5 specific and take into account display size, font types, color etc. as well as the particular 
markup language(s) supported by the target electronic device 104. 

The server browser 110 has connectivity manager 132 for interacting with the 
client browser 112. Connectivity manager 132 sends and receives information to the 
client browser 112 using an event format and protocol such as a proprietary format (e.g., 
10 OBML, described below) and XML event messages. According to the requirements of 
the electronic device 104, the events may be translated via the event translator 136 (FIG. 
1) to use an externally defined format and protocol such as WML and WAP. 

Referring back to FIG. 1, the event translator 136 preferably provides the server 
browser 110 with compatibility with any standard client browser 140 or end user 
15 application that employs a known protocol such as HTTP. Current examples of such 
standard client browsers 140 include both WAP and non-WAP based WML browsers, 
HTML browsers, XHTML browsers, as well as both iMode and non-iMode compact- 
HTML (cHTML) browsers. 

FIG. 3 is a .diagram further illustrating exemplary uses for the event translator of 
20 FIG. 1. The event translator 136 can be utilized on the server browser 110 side or the 
client browser 112 side, depending on which client browser 112 or standard client 
browser 140 is utilized. According to the server browser 110 side, the event translator 
136 operates as the interface between a standard client browser 140 and the information 
content data stored in a DOM format at the server browser 110. Preferably, the DOM is a 

25 QDOM 116 that identifies each node in the document using a unique value. According to 
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the client browser 112 side, the event translator 136 can exist on the client browser 112 
and provide an interface between the third party viewer and the micro-gateway 144. One 
skilled in the art would appreciate that the event translator 136 is not limited to the server 
browser 110 side or the client browser 112 side, but can also operate between and 
5 externally to the server browser 110 and client browser 1 1 2, if so desired. 

Preferably, the event translator 136 translates requests for information content to: 
known events that can be used to generate or modify a DOM tree, dynamically assigns 
unique device identifiers to identify the information source 102 of standard client browser 
140 events, sends events and receives responses to and from the server browser 110, and 
10 manages sessions and transactions (including timeouts, authentication, error handling 
etc.) 

Referring back to FIG. 1, the client browser 112 can be hosted on an electronic 
device 104 such as a PDA, handheld PC, mobile phone or any device with sufficient 
navigation and presentation capability. The client browser 112 provides the user interface 

15 for presentation or rendering of the retrieved information as well navigational capability. 

Furthermore, portions of the client browser 1 12 may be used by a standard or 
commercially available client browser. In such examples, the client browser 112 can 
provide distributed browser functionality that is compatible with the standard or 
commercially available client browser. 

20 Moreover, the electronic device 104 is preferably validated by user/appliance ID, 

which can be stored within a database on a server. This ID authenticates the electronic 
device 104 and validates that it is allowed to access specific data content found in a 
particular data source. 
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In an exemplary embodiment, the client browser 112 can access information 
content via the server browser 110. Additionally, the client browser 112 preferably 
allows the user to submit information content or form data back to the information source 
102. The form data is a response to a query posed by the data content of a particular 
5 document from the information source 102. Events containing the data for each 
component in the form are forwarded to the server browser 110 by the electronic device 
1 04 where they are formatted in accordance with the content of that document by the 
server browser 110. The result may be an error notification (e.g. network timeout, bad 
data, etc.) or display of a new document received from the server browser 1 12 as a result 

10 of server side 112 processing of the submitted form data. 

Referring now to FIG. 4, the client browser 112 preferably includes a 
microbrowser 148, event controller 152, and DOM store 116 according to the industry 
standard Model View Controller (MVC) representation. The microbrowser 148 is one 
example of an end user "View" application and represents information such as graphical 

15 or textual display, or audio to the user. The event controller 152 processes events to and 
from the server browser 110. The DOM store 124 is utilized for caching the information 
content received over the communications network 114. 

The event controller 152 and the DOM store 124 operate as a micro-gateway 144 
between the server browser 110 and an application 168 for interaction with the end user. 

20 In the exemplary embodiment the application 168 presents a typical browser interface 

allowing display and navigation of content, form interaction and submission and so forth. 

It should be understood, however, that the micro-gateway 144 can also support multiple 

different end user applications 172 on the electronic device depending on their 

availability and the nature and type of content data delivered to it. Examples of such end 

25 user applications include, but are not limited to, email, instant messaging, media players 
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and other such plug-ins. Further, multiple different kinds of browsers designed for 
particular markup types (HTML, cHTML, WML, etc.) and so forth can also be supported 
by the micro-gateway 144. 

In one aspect of the exemplary embodiment, the micro-gateway 144 presents an 
5 external interface to other applications 16S and 172 that consists of a well defined 
interface to the DOM Store 124 component and an interface to the event controller 152 
using the same event model that is described below for communications internal to the 
distributed browser, hi another embodiment, the micro-gateway 144 can be combined 
with the end user application 168 and 172 and use a more tightly coupled internal 
10 interface. 

Additionally, the micro-gateway 144 can use an event translator (not shown in 
FIG. 4) to provide an interface to third party or commercially available applications such 
as HTML or WML or cHTML browsers. For example, according to an aspect of the 
present embodiment, a micro-gateway 144 and an event translator to cHTML can be used 

15 to provide an interface between the server browser component and the third party cHTML 
browser known as Pocket Internet Explorer on a Pocket PC device running the Microsoft 
Windows CE operating system. 

The microbrowser 148, renders the information content transmitted to the client 
browser 112 by the server browser 110. In the exemplary embodiment, the rendering 

20 includes visual representations (both textual and graphical) of the markup elements, but 
can be extended to provide other representations (e.g., audio) according to the capabilities 
of the electronic device 104. The format of the representations can be fixed by particular 
microbrowser 148 implementations such as a WML or proprietary (e.g., OBML) browser, 
or can be modified according to an XSLT style defined in conjunction with the content 

25 markup. 
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Typically the microbrowser 148 is used to directly display markup based content 
received through the micro-gateway 172. In addition, the markup based content can be 
used to adaptively tailor the microbrowser 148 according to directives contained in the 
information content. Adaptations can include embedding application logic in the content 
5 presentation, modifications to the interface (menus, titles, etc.) and other configuration of 
the browser application or device. 

It should be understood, however, that an additional property of the browser is the 
ability to download and install other applications or plug-ins as needed to support non- 
markup based content, including images, audio, video, and multipurpose internet mail 
10 extensions (MIME) or secure MIME (S/MIME) document formats such as plain text, 
Acrobat (e.g., ,! *.pdf ' format), Microsoft Word and so forth. Content of these types is can 
be .viewed through the use of these other applications or plug-ins by the micro-gateway 
144 or microbrowser 148, or both 144 and 148. 

Preferably, the event controller 152 is an event handler. Events to and from the 
15 server browser 1 10 are formatted according to the particular electronic device 104 in use. 
In the exemplary embodiment, XML event messages and a proprietary protocol are 
interpreted by the event controller 152 to manage data and events to and from the server 
browser 110. 

The DOM store 124 provides a secondary cache of the information content stored 

20 on the server browser 110. The secondary cache preferably resides on the electronic 

device 104 to reduce the need to pass data between the server and client browsers 110 and 

1 12, respectfully. The information content that the user desires is transmitted to the client 

browser 112 from the server browser 110. In the exemplary embodiment, however, once 

the information has been transmitted, it is stored for reuse. The information content is 

25 retained on the electronic device 104 while it is valid and while there is sufficient space to 
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store it. The information content is stored in a DOM structure according to the W3C 
definition of an XML document and can be accessed by the microbrowser 148 or other 
applications on the client browser 112. 

When the DOM is examined or modified, the event controller 152 preferably 
5 delegates the event to the DOM facade 118. These events includes click, blurchange, 
submit, expand, etc. 

In the case of a click event, the DOM facade 118 preferably examines and 

executes the content and/or script associated with clicking on a given node. In the case of 

an bulrchange event, the DOM facade 118 preferably modifies the DOM so it reflects that 

10 the user has provided data. In the case of a submit event, the DOM facade 118 preferably 

examines the existing user input to formulate an appropriate form submission request. In 

the case of an expand event, the DOM facade 118 preferably delegates to a serializer to 

server the contents of a given folder to the client browser. 

In cases where a standard browser (cHTML, WML, XHTML, etc.) is used, there 

15 is preferably no event controller. The requests from the standard browser are interpreted 

and translated by the event translator into events that the DOM facade 118 understands. 

An "active" page is a page from the information source that is of higher than 

normal interest to the user of the client browser 112. It is given an active status in the 

cache and retained on the electronic device 14 when it otherwise might have been deleted 

20 for space or timing reasons. Where a document has been made part of the "active" cache 

(either through a push from the server or explicitly requested by the user through a client 

application such as the micro-browser), the content and any related data for that document 

can be accessed when the electronic device 104 is out of coverage. 

Preferably, the client browser 112 handles "active" page content submissions 

25 separately and can store form data for those submissions to allow repeated attempts to 
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submit that data until either the submission is successful or the user explicitly instructs 
the client browser application to delete the forai data. Delivery of form submission data 
for the "active" content pages is guaranteed by the storage of the data in the client 
application browser. 

Further, the client browser 112 retains the context of "active" page submissions 
and allows the user to access a history of chained interactions with the information source 
as a series of submissions of data and responses to the submissions. Note that each 
response can itself require a further submission and in turn generate another response, 
thus forming the chain. The status of an active submission in progress can also be viewed 
in the client browser. 

The distributed browser 108 preferably utilizes send and receive events to convey 
information between the server and client browser 110 and 112, respectively. Events 
between these components can be classed as an events message, 
acknowledgment/negative acknowledgment (ACK/NAK) message, security handshake 
request/response, and decrypt ACK/NAK message. 

An events message preferably carries information between the server and client 
browsers 110 and 1 12, respectively. An ACK/NAK message is used to confirm or deny 
receipt of an events message. A security handshake message is used to transport 
information used by encryption and decryption routines. A decrypt ACK/NAK is used to 
report success or failure in the security routines. 

The first byte of the messages preferably contains an identifier that uniquely 
defines which type of message is contained in the data being sent. The 2-byte integral 
values are always "little endian" or bytes at lower addresses have lower significance. 

FIG. 5 shows the structure of an exemplary events message that is transmitted 

between the server browser 1 10 and the microbrowser 148 (i.e., via the network interface 
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156 and event controller 152). The event message may be modified or intercepted by 
the event controller 152. The event message includes header identifier, header version 
number, and the unique message identifier. Additionally, the event message also includes 
the event type such as response, original, push, or stop. Moreover, event data is included 
5 at the end of the events message. 

The event data area of the events message may be compressed and/or encrypted as 
specified in the header component. When converted to plain text, the data area is defined 
as having the following exemplary structure: 

<XML Events Message> = <Event Protocol VersionxEvent SeparatorxSession 

ID><Event Separator><XML EventsxEOM> 

<E vent Protocol Version> = Integer 

<SessionID> = <Server Session ID> | 

<Server Session IDxinteger separatorxCUent Session 
ID> 

<Server Session ID> = <Device Type><integer separatorxPage ID> 

<DeviceType> = Integer (uniquely identifying different devices) 

<PageID> = Integer 

<Client Session ID> = Integer 

<XML Events> = <Event> | 

^ <EventxEvent SeparatorxXMLEvents> 

<Event> = <EventIDxfieldseparatorxXMLNode><field 

separatorxAttributes> 
<Event ID> = integer (see table below) 

<XMLNode> = Integer 

<Attributes> = <value> | 

<value><value separatorxAttributes> 
<value> = ASCIItext 

<EOM> = \r\n (OxOD OxOA) 

<Event Separator> = | 

<Field separator> = * 

<Value separator> = A 

<Integer separator> = , 

10 All events contained within an events message belong to the same session or page of 
content. 

When there is only a single client browser 112 on the electronic device 104, the 
session id information needs only to specify an identifier for the server browser 110 
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session or content page. When there are multiple client browsers on the electronic 
device 104. (e.g. multiple browser windows, browser + instant message client, or other 
combinations), the events message should identify which client browser 112 it is 
associated with. 

5 Preferably, the page id is generated on the server browser 110. When the client 

browser 112 has no valid server session id to send, a zero will be sent. Zero is not used as 
a valid session id. 

For any Uniform Resource Locator (URL) data that is contained in an events 
message, standard URL encoding as is known in the art, is used to ensure that the 
10 information content does not include any of the characters special to a proprietary packet 
format (i.e., "|", ,tA ", and "*"). For any XML content contained in an events message, 
standard HTML encoding, as is known in the art, is used (e.g., where characters can be 
represented by "&#n; M where n is the ASCII code for that character). 

The node value maps directly to a node in the DOM tree (e.g., output of the 
15 QDOM 1 16 in FIG. 2) and signifies the node affected by the event. For some events (e.g. 
load, error) the node is set to 0, indicating that there is no direct connection to a particular 
node. Other events (e.g. expand, onblurchange, submit, onclick) have a direct correlation 
to an element in the QDOM and are targeted to that element by the value set in the events 
message. 

20 The following table lists the different events that can be contained within an 

events message: 



Event 


Attribute list 


Description 


Cleaned 


(none) 


Notification to clients that old data has been 
purged so that clients can check any cached 
page references 


Error 


Error message 


Description of an error on server 
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Event 


Attribute list 


Description 


Expand 


(none) 


Client request for content of a nomializer 
folder 


Expand 


Document 


Content of a noimalizer folder 


Load 


URL, summary 
option, table option, 
JavaScript option 


Client request for a new content page, 
including options on whether to normalize, 
include tables and allow JavaScript 
processing 


Load 


URL, summary 
option, table option, 
JavaScript option, 
document 


Content page response or push from server, . 
including options set in original request 


Notify 


Message data 


Non-error message to client(s) 


Onblurchange 


new value for input 
element 


The user has changed the content of an input 
element and moved focus away from it 


Onclick 


(none) 


Click on link element 


Reload 


(none) 


User wishes to force a reload of the current 
content page in the device application. The 
server will replace any existing session with a 
new load of the page from the web . 


Stop 


(none) 


User request to stop any message identified 
by the MessageDD in the header. 


Submit 


(none) 


User has completed a form and is submitting 
all onblurchange data to the server 


Authenticate 


Realm 


The remote HTTP server issued a challenge 
string requiring the user to prove possession 
ui d. vdiia user lu ana password lor trie realm 


Authenticate 


Authentication tokens 


<username>:<password>, encoded in Base64 
to be submitted back to the origin server 


Alert 


Message 


ocrver miuaieu message, me device displays 
the alert message followed by an OK button. 


At j 

Alert 


(none) 


Device returns when the user presses OK. 


Confirm 


Question 


Server initiated message. The device displays 
the question followed by an OK and Cancel 
button. 


Confirm 


confirmation status 


Device returns the button pressed. 


Prompt 


Message, default 


Server initiated message. The device displays 
the message followed by a text input field and 
UJs^ Clear and Cancel buttons. The default 
message is displayed as the initial input. 


Prompt 


Button pressed, return 
string 


If the user clicks the cancel button, return 
string should be null. If the user clicks the OK 
button, Device returns the value currently 
displayed in the input field. 
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To conserve bandwidth over the communications network 114 between the 

connectivity manager 36 and the radio interface 156, an events message may contain 

more than one event. In one exemplary embodiment, all onblurchange events are stored 

by the microbrowser. 148 until a submit event is generated. At that point they are bundled 

5 together into a single events message for transmission to the server browser 110. 

FIG. 6 shows the structure of an exemplary transmission ACK/NAK message that 

is transmitted between the radio interface (156 of FIG. 4) and connectivity (132 of FIG. 

2). An ACK message is preferably used when the underlying communications network 

114 does not provide message delivery confirmation to the network interface 156 and 

10 connectivity manager 132. A NAK message signifies that although an events message 

was received, it could not be processed (e.g. because of low memory conditions). 

FIG. 7 shows the structure of an exemplary message used by the security 

subsystems of the connectivity manager 132 and the network interface 156. The security 

handshake request and security handshake response messages are used to exchange public 

15 keys between the connectivity manager 132 and network interface 156. The security 

ACK and NAK messages are used to signify successful decryption of events messages 

that have been encrypted using the shared public keys. Receipt of a security NAK 

message at any time or a need to encrypt the data in an events message when public keys 

have not been shared preferably initiate a security handshake request. . 

20 The server browser 110 includes a QDOM 116. The QDOM 116 utilizes a in- 

memory representation of an document tree as a single mutable object or creation of a 

DOM does not require creation of a language object for every node of the tree, whether 

that language happens to be Java or C++ or another object oriented language. 

The mutability of a QDOM 1 16 is preferred, because transformations of the DOM 

25 tree will be applied, resulting in a new tree structure within the same QDOM Object. The 
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architecture of a QDOM 116 allows these transformations to be performed in an 
efficient manner with regard to both speed and resources used. 

A QDOM 116 consists of an aggregation of N re-usable buffers that contain 
arrays of raw bytes. As the QDOM grows, additional re-usable buffers are added, only as 
5 needed. Some of the re-usable buffers contain binary information describing the DOM 
tree structure, tree dependencies, and references to information content data. Other 
buffers contain the actual content data. 

FIG. 8 shows one exemplary embodiment in which separate QDOM 116 arrays 
180 are used for the values representing the following properties of each element node 
10 184: element name tag 188, parent node 192, previous element sibling 196, next element 
sibling 200, first child element 204, and first attribute 208. Similarly, each attribute node 
can be described with the following properties including attribute name tag, attribute 
value tag, previous attribute sibling, and next attribute sibling. Separate arrays can be 
stored in the QDOM i 16 for attribute data, or it can be overlaid in the same arrays used 
15 for element data. 

In another exemplary embodiment, the same information can be stored in 
structures for each node and attribute. The QDOM 116 contains one or more arrays of 
each of these structures. The choice of the means of storage depends on the functionality 
j of the programming language employed for the QDOM. 
20 The actual string names of the tags and attributes of tree elements are replaced by 

a corresponding value equivalent. A dictionary of the strings and their corresponding 
value is preferably built up as necessary to deal with a particular set of XML tags. For 
performance reasons, pre-compiled dictionaries can be used for the well-known markup 
languages, such as HTML or WML. 
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FIG. 9 shows a re-usable content buffer 212 that the QDOM array 180 references 
when information content that is not well known (such as plain text data) is used. The 
QDOM array 1 80 preferably stores the start and end positions of the text in the content 
buffer 212. In another exemplary embodiment, the content buffer 212 stores zero 
5 terminated strings and the QDOM array 180 stores the start position. 

Preferably, the interface to the QDOM 1 16 is value based because every node (for 
example, see 1 84 in FIG. 8) of the tree has a unique value associated with it. All 
operations on the nodes in the tree that the interface provides can be carried out using that 
value as a reference to the affected nodes. All comparisons between nodes are also value 
10 based, so expensive string comparisons can be avoided. 

Since the underlying structure of the QDOM 116 groups of raw bytes, it can easily 
and efficiently be serialized to and from permanent storage, thus reducing the amount of 
random access memory (RAM) memory necessary to support multiple users and multiple 
documents per user. 

15 In situations where resources are limited, such as on a PDA, the QDOM 116 

structure in the form of DOM store, XMLDocument, and XMLelement (124, 162, and 
164 in FIG. 4 respectfully) can also be used efficiently by the client browser 112. The 
QDOM storage is divided into smaller groups that are held in a permanent storage area 
(e.g., FLASH). Only such groups as are needed for the current operations on the QDOM 

20 are retained in or moved to a fast memory area (e.g. RAM). This provides high 

performance through an efficient use of the data in RAM while still minimizing the actual 

resource load in use at any one time. 

A QDOM 116 is implemented as a re-usable object, so rather than deleting it and 

having a "garbage collector" reclaim a space occupied by the document, the QDOM 116 

25 can be easily and efficiently re-initialized and used to store some other XML Document. 

30 

8NSDOCID; <WO_O2067135A2J_> 



WO 02/087135 PCT/US02/I3173 

A number of preliminary tests have been taken to determine the time saved using 
the QDOM 1 16 as compared to the node-based interface of the standard W3C DOM. The 
tests show more than lOOx improvement over other W3C compliant models. 

The normalizer organizes the DOM tree into tiers or folders under headings that 
5 contain related content. The result is a set of hierarchical DOM node collections. The 
characteristics of font, font size, font color, hue saturation comparison of background and 
foreground color and Cascading Style Sheet or XSLT properties are used to determine the 
weight of a text node. The weight is then used to determine whether it will be inserted 
into a normalized document tree as a parent or child. The parent nodes become folder 
10 titles and the child nodes become the folder contents. Thus, higher weight document 
objects are pushed to the top of the tree so the user can decide whether to "walk" down 
the branch or not. 

The normalizer dynamically streamlines and folderized the content automatically 
or via predefined additional rules to achieve automatically an experience similar to 

15 reading a newspaper. The normalizer including the template normalizer and meta-tags 
allow the content source to be redefined once for all networks and device types. The 
alternative technologies in the industry are large cycle time, re-development of the 
content, often specific to one or more of the following: each device ergonomics, or a 
particular client-only browser, or a particular network type. 

20 The goal to normalizing is to adapt desktop focus web content to handheld 

browsers. This requires filtering unsupported content, dropping unneeded content, 
reordering and partitioning content to improve navigation and application flow for display 
on a limited device. Some of the functions to normalization are folderize/partition 
content, drop content not required on a handheld device, reorder content, provide 

25 prompts/names to input elements 
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The normalization process can utilize a weighted heuristic and pattern 
recognition to create a the contextual relationship of with nodes in the source tree. The 
output from the normalization process is a hierarchical content tree. Preferably, the 
normalized tree is not specific to a particular presentation language. Therefore it can be 
5 transcoded for display by any type of client browser. 

Content collapsing rules in the automatic normalizer utilize the previous page 
loaded to determine if similar constructs exist in a page which can be collapsed into 
folders or selectable input elements on subsequent loads. This is performed by comparing 
the previous page loaded with the current page. The trees of the documents are compared 

10 to determine if similar fragments (list of links, table, image) exist. The similar fragments 
of the tree are collapsed into folders or select input elements. The effect is to conserve 
display space on the device. 

Electronic devices can have limited display characteristics such as display size, 
font types, color etc. Most web content is tailored for display on desktop browsers which 

15 not only suppose a large screen, but also support a rich set of fonts, colors, and formatting 
constructs such as tables and frames. The normalizer adapts existing information content 
for display on the electronic device 104. The normalizer 124 includes an automatic 
normalizer 80 and template normalizer 84. 

Referring back to FIG. 2, the automatic normalizer 80 in the normalizer 124 

20 maintains the context of the information content before taking the electronic device 104 
specifics into account The automatic normalization process does this by organizing the 
information content into folders. The result of this approach is that sets of nested folders 
are created which the user can "walk" the information content on the electronic device 
104. The titles of the folders are sent to the electronic device 104 first and the user can 

25 determine if the contents of particular folders are of interest. This not only increases 
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usability in terms of reduced content to scroll through for the user and time spent 

scrolling through the page, it also optimizes wireless bandwidth utilization because less 

data is sent to the electronic device 104. 

It should be noted that while the exemplary embodiments of the normalizer 

5 processes concentrate on the normalization of HTML content, including that generated by 

scripting technologies such as JavaScript, these same processes can be applied to other 

markup content. It is well suited to any XML content. 

The automatic normalization process traverses a DOM tree from the QDOM 116 

40 and creates a new, normalized tree. Preferably, the original DOM is transformed 

10 rather than copied, so that it becomes the normalized tree itself. This provides both 

efficient performance and efficient memory utilization. 

The normalization process begins with the root node of the document and 

traverses the tree along a depth first path to maintain context at all times. 

If a node is the beginning of a table, a table pattern recognition process is 

15 preferably executed. The entire table is weighted and pattern recognition criteria are 

compared to determine if the table matches a defined pattern. The table recognition 

criteria define a profile for different data table types. Each cell in the criteria is defined to 

be either greater than, less than or equal to a root table weight, a "don't care" or defined to 

contain certain nodes such as anchors or images. The root table weight can be derived 

20 from any cell in the table such as the cell at position row 0, column 0 or can be derived 

outside the context of the table. These criteria define the pattern that is attempting to be 

matched. If a pattern is recognized, the table cells are formatted corresponding to that 

pattern. If a pattern cannot be recognized, the weighted node processing continues. 

The major part of the weighted node process is the maintenance of a weighted 

25 node stack. The first element of that stack is always the "DOCUMENT" itself, having by 
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default the highest possible weight. The normalization process takes the next node from 
the DOM tree. The node is first filtered to determine if it has an effect on weighting or 
presentation. If the node is not significant it is preferably dropped. Nodes such as the 
HTML tag in HTML are not significant since the tag has no effect on presentation. Next 
it is determined whether the node is a weighting node or a content node. Weighting 
nodes are nodes that affect the display of rendered content such as a bold or heading 
format tag. Some weighted tags may have a negative weight that allows nesting of the 
tags and emulates a hierarchy of nodes weights such as nested list items. Content nodes 
are nodes such as text nodes, input nodes, and image nodes. 

When a weighted node is encountered, the node weight is added to the 
accumulated weight. When a content node is encountered it is assigned the accumulated 
weight and becomes a weighted node. The weighted node finds its position on the 
weighted node stack by finding the lightest element on the stack with a weight greater 
than his (node's parent). Stack nodes from that point on are preferably deleted from the 
stack. The new weighted node becomes a child node for that parent. When the node goes 
out of scope (e.g. if a TABLE is ended), the normalization process checks the weighted 
node stack to remove all nodes that belonged to the expired scope of influence. 

For example, if the node on the weighted node stack is part of a table and the table 
scope of influence has expired, then that node is removed from the weighted node stack. 
However, if that node belongs to more than one scope of influence (e.g. it is part of one 
table nested inside another table), all scopes of influences are checked against that node 
and it is removed preferably when they are all expired. When the inner table ends, node 
stays until it replaced by a heavier node or the outer table ends. 

The template normalizer 84 is a tool for recognizing patterns within a document 

through a DOM tree and applying changes to those patterns as specified in the template 
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syntax. Preferably the template normalizer S4 is part of a larger process of normalizing 
all documents. One step of the larger process is an attempt to match and apply templates 
where possible. . 

The template normalizer 84 preferably handles numerous variations of the same 
5 document as dictated by the application logic that produces it. For example, if a certain 
data table could have various numbers of columns and rows, or even not be present in the 
document at all, the template normalizer S4 is preferably still capable of dealing with 
those variations. 

The template normalizer 84 is capable of recognizing an document from a set of 
10 potential documents that could be produced by the application. For example, if the 

application produces two completely different documents depending on whether a user is 

logged on or not, a single template could still recognize the outcome and apply its 

changes to either one. 

The template normalizer 84 is also capable of recognizing a change in the overall 
15 structure of the document to determine when its rules are not applicable any longer. In 

that case, it will not attempt to apply the changes, but will convey the document to an 

automatic normalizer 80. 

The template normalizer 84 uses a regular expression pattern-matching machine 

as applicable to DOM trees. The syntax of a template is strict XML as described by the 
20 World Wide Web Consortium (www.w3c.org) and includes a number of proprietary 

regular expression tags and attributes that describe how the template normalizer 84 should 

match and modify original content. 

Tags: 

<xgrp> equivalent to a bracket in Regular Expressions 

25 <xany> equivalent to a wild card in Regular expressions 

<xalt> equivalent to c or' in Regular expressions 

<xadd> signifies the addition of contained markup 
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<xnone> 



equivalent to "empty" in Regular Expressions 



Attributes: 



'xtimes 5 



the number of times to apply a recurring pattern 
specifies a new title for a matched pattern 
specifies a name of an XML node 
re-parent an XML node to a specified element 
delete a node from the tree 



'xtitle 5 
E xid" 



"xparentf 
"xdrop" 



"xforniat" produce a formatting attribute for an input field 
"xaction" apply a user-specified algorithm to the branch of a tree 

The normalization process preferably scans a dictionary of templates and an initial 

comparison is made based on a URL specified for the template and the URL of a 

document to be processed. If the URLs match, then the template normalization process 

begins. 

The template normalizer 84 deals with a document or XML document in two 
steps: first it uses the regular expression pattern-matching machine to impose itself over a 
document and attempts to match the template to the document content. The match is 
performed using the regular expression tags in the template to apply standard regular 
expression algorithms. If that process fails, the changes specified by the template are not 
applied, and the document is conveyed to the automatic normalizer 80. 

If the match process succeeds, the template normalizer 84 will apply changes as 
specified by the attributes of the matched regular expression elements. Changes include 
dropping nodes, creation of new folders or tiers, re-parenting nodes, assigning new titles 
to nodes, etc. 

During the application of the changes, the template normalizer 84 can use a 
complex state variable syntax to refer to the parts of the document. These variables can 
be set as pointers to nodes in the DOM or counters. Resolution of a variable expression 
starts with the inner most expression and is processed outward. This is similar to list 
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processing in the LISP programming language. The inner resolutions are used to resolve 
subsequent resolutions. 

Where a counter is used in a variable expression, the variable will be resolved 
using the current value of the counter. 
5 Resolution Example: 

If $z = a and $ya = "data" the expression $(y($z)) would be resolved to 
$(y$(z)) = $ya="data". 

$2 gets resolved to a and this creates the expression $ya which is then resolved to 

"data". 
10 Counter example: 

If xcounter= ,f x" and the first iteration of an Xgrp is occurring, then the expression 
$a($x) will be resolved to 

Sal. 

If a variable is used in the context of an Xtitle attribute, the value for the variable 

15 is derived from the text value of the DOM node that is referenced by the variable. 

If the variable is used in the context of an xparent, then the variable is resolved to 

a DOM node to which to move the referring node as a child. 

The xid attribute is used to set the value of a variable to the DOM node. 

Template normalization involves matching. a template DOM tree with an input 

20 DOM tree and applying changes to the input DOM tree. The automatic normalization 

. algorithms may be called during the apply step of template normalization where specified 

by the xaction attribute. . 

With integration of the automatic normalization algorithms, a template can be 

utilized to drop and reorder content while calling the automatic normalization algorithms 

25 to partition the content into a hierarchical set of folders. 
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FIGS. 11 and 12 illustrate the flow of logic in the exemplary embodiment for 
determining when to apply the automatic, markup assisted or template normalize!" 84 
algorithms. It should be noted, however, that the process is not restricted to the current 
flow, but can include variations such as the application of the automatic normalizer before 
5 the application of the template normalizer. 

At step 220, a DOM tree is preferably obtained from the QDOM and input into the 
normalizer. ' 

At step 224, the normalizer determines if a template exists for the DOM tree of the 
document. If the template does not exist, the DOM tree is forwarded to the automatic 
10 normalizer for processing per step 232. If a template does exist, the DOM tree is 
forwarded to the template normalizer for processing per step 228. 

At step 228, the template normalizer determines if the existing template matches 
the DOM tree per step 236. If the template does not match per step 236, the DOM tree is 
forwarded to the automatic normalizer for processing per step 232. If the template does 
15 match the DOM tree per step 236, the DOM tree is forwarded to the template application 
process per step 240 (and expanded in FIG. 1 10). 

At step 244, if the template apply process fails, then the DOM tree is forwarded to 
the automatic normalizer per step 232. If the template apply process is successful, then 
the DOM tree has been normalized into a normalized tree. 
20 At step 248, the normalized tree is forwarded to the serializer for transmission to 

the electronic device via the connectivity manager. 

At step 232, the automatic normalizer is applied. 

At step 252, it is determined if the DOM tree has normalization markup or meta- 
tags. If the document does not have normalization markup or meta-tags, the DOM tree is 
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forwarded to step 260. If the document does have normalization markup or meta-tags, 
the DOM tree is forwarded to the markup assisted processing per step 256. 

At step 256, the normalization markup or meta-tags are utilized to assist in 
normalizing the DOM tree into a normalized tree. Hie normalization markup can provide 
5 instruction to the automatic noimalizer to create the normalized tree. The normalized tree 
is forwarded on to the serializer per step 248. 

At step 260, the DOM tree is normalized using a "best guess" processing. After 
step 260, the DOM tree is normalized into a normalized tree and forward on to the 
serializer per step 248. 

10 According to FIG. 11, the template apply process per step 240 is further 

illustrated. 

At step 264, the template apply process determines to use the automatic 
normalizer process per step 268 or the template rules process per step 272. If the 
template apply process determines to use the automatic normalizer rules, the DOM tree is 
15 forwarded to step 268. If the template apply process determines to use the template rules, 
the DOM tree is forwarded to the apply the template rules per step 272. If the template 
rules are applied per step 272, the DOM tree has been successfully normalized and 
returns to the normalization process per step 288. 

At step 268, the normalization rules such as user profile, statistics, keywords, 

20 history, are applied and the DOM tree is forwarded to step 276 to determine if the 

document contains normalization markup. If the document does not contain 

normalization markup, the DOM tree is forwarded to markup assisted processing per step 

280. If (he document contains normalization markup, the DOM tree is forwarded to the 

"best guessing" processing for applying pattern recognition and weighting heuristics to 

25 the DOM tree and forwarded to the normalization process per step 288. 
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Some devices (e.g. those with small screens) do not support the display of tables 
as in a traditional desktop browser. The problem is determining how to extract content 
from the table into a linear form so that it is presentable on the device. Table pattern 
recognition looks for tables that conform to some of the more common uses of the tables 
5 for data presentation. A weighting and comparison of table cell nodes in the DOM tree 
against each other is used to determine the order in which to extract cell data from the 
DOM tree. The comparison of weights attempts to determine if the nodes match a 
recognized table pattern. Cell weights are assigned in the same manner as the general 
normalization process, but other characteristics are also compared. 'Other characteristics' 
10 preferably includes the type of cell element (table heading or table data) and if the table 
cell contains an anchor or an image, but may extend to any particular attribute of the cell 
data. 

FIG 13 shows an example Table Pattern as formatted in the original content for a 
wide screen display (desktop) and reformatted for a small screen device. In this table the 
15 first row of table cells contain heavy weight text nodes. These nodes will become 
headings/parents for the columns. The following rows will become children of the parent 
nodes as shown in the small screen display result. 

The general normalization rules may not apply to all web sites. Therefore it may 
be possible to specify specific rules on a URL basis. Preferably, URLs can be matched 
20 exactly or partially, such as in the matching of the domain name component only. 

The concept behind adaptive browsing is that most users hit certain links or 
objects in a document more than others. The user's statistics can be used to increase the 
priority/weight of an object in the tree in order that the user be displayed that object first. 
This allows the page to be adapted to the user's tendency/habits. This mechanism will 
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aide in browsing efficiency for the user. Content nodes will accumulate more weight 
based on the statistics on, for example, the click count on an anchor. 

A User can provide keywords for his profile that can be used to assign weights to 
the document content. Content matching any keywords would be pushed to the top of 
5 the tree by assigning higher weights to the matched elements. 

Markup assisted normalization defines a wireless specific markup that conforms 
to HTML 3.2 and 4.0 specifications and does not affect the page for display by other 
HTML browsers. 

The markup defines a set of attributes that can be introduced to existing HTML 
10 content. These attributes are triggers for the automatic normalization process to perform 
certain operations such as move content or create a folder. 
TAGS: 

HTML <meta> tag - <meta wireless:ml="true|false"> 

If a meta tag exists in the <head> of the HTML page with the wirelesstml attribute 
15 set to true, the automatic normalizer will be triggered to perform markup based 
normalization. 

HTML <div> tag 

A div tag with wireless attributes is used to encompass blocks of HTML which 
will be processed by the automatic normalizer. The wireless attributes assigned to the div 
20 tag will not affect display of the content on HTML desktop browsers. 

The markup is extensible in that other attributes may be added in the future to 
trigger other automatic normalization behavior such as wireless specific javascript. 

HTML <style> tag 
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The style tag is used to encompass arbitrary blocks of HTML that will only be 
processed by the automatic normalizer. Preferably, the content encompassed by the style 
tag will not be displayed on HTML desktop browsers. 
Attributes: 
5 <div> attributes 



wireless: action: (default behaviour = autonormalize) 





drop the content encompassed by the div from the 
wireless content 


colbycoltablenormalizer 


call a formatter on a table which extracts the data column 
by column 


rowbyrowtablenormalizer 


call a formatter on a table which extracts the data row by 
row 


Folder 


create a folder with a given title which will contain the 
encompassed content 


Mark 


mark a place in the content with an id 


Move 


move the encompassed content to marked position or 
folder 


Include 


include a block of html defined in a style block 


Autonormalize 


call the automatic normalizer on the encompassed content 


Passthru 


pass the content encompassed by the div to the handheld 
as is 



wireless:id: 

sets an identification string for the folder, mark, move or include action. 
wireless:title: 
10 used to name a folder. 

wireless:href: 

used in conjunction with the menu action and the folder action to define an 
anchor/href link in the wireless page 
<style> attributes 
15 wireless:id: 

an identification string for the block of html which can be included into the 
wireless page. 

For example: 
<html> 
20 <head> 

<meta wireless :ml— c true"/> 

<style wireless:id="html block"> 
block of html which can be included in the wireless page 
</style> 
25 </head> 
<body> 

<div wireless: action- 'include" wireless:id="html blocks 
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</div> 
<7body> 
</html> 1 

5 Referring back to FIG. 1, the distributed browser 108 preferably appears to the 

information source 102 as a client interface, such as a PC that is browsing an Intranet or 
Internet. However, when the server browser 110 receives the information content plus 
script code, it can create an XML based Document Object Model ("DOM") tree structure. 
This structure can organize the information content into a structured format that is 

10 interpreted and processed by the normaiizer to organize the information content into 
folders or tiers. After the information content is in a structured format, the server browser 
110 can forward the structured format to the client browser 112 hosted on the target 
electronic device 1 04. 

Furthermore, information content can be transmitted from the server browser 110 

15 to the client browser 112 without first receiving a request from the client browser 112. 
Therefore, information content such as in channels of desirable content like sports, 
weather, and stocks can be forwarded to the server browser 110 at periodic intervals. 
Additionally, the information content sent to the client browser 112 can include a note. 
Such a note could inform the user of the client browser 112 that additional information 

20 content is stored at the information source 1 02 or server browser 1 1 0, or both. 

In any markup language (e.g. WML, HTML, cHTML, XHTML, etc.) the source 
content contains two distinct types of information - information that is visible to the user 
and information that carries processing instructions to the browser or viewer (e.g. a URI 
for new content to load when an element is selected, rules governing how to submit form 

25 data to the content source, etc.). . The latter type of information, while not visible to the 
user, often occupies more than 50% of the total source.HTML code. 
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Through the use of Object Based Markup Language (OBML), a proprietary 
markup language, an object aware distributed browser can take advantage of this 
distinction of information to leave the majority of the processing information on the 
server side and only send the end user visible information to the client browser. Under 
5 this scheme, the client version of the DOM will thus represent a functionally equivalent, 
but stripped-down version of the original DOM, allowing for efficiency in both content 
transmission to the device and event handling between the server and client components. 

In order to support this scheme, every node in the original server side DOM is 
assigned a unique number. Every DOM node that has a processing instruction associated 
10 with it (e.g. in HTML this could be a link to follow when it is clicked), a **P pointer*' 
attribute for that node is sent down to the client browser. Since it is unique, the P pointer 
can identify the element back to the server. 
For example: 

A DOM on the server side contains the following anchor information at node 1 234 

15 <a href="/hockey/nhl/2001/playoffs/news/2001/04/l 5/kings_red.wings_ap/?s=4" 

>Kings beat Wings 2-1, end 14-game playoff skid</a> 

When formatted in OBML, this node is represented as 

<a p="1245">Kings beat Wings 2-1, end 14-game playoff skid</a> 

20 This represents a significant savings on the amount of data that needs to be sent to the 
client over a network (e.g., wireless network). An event back to the server indicating that 
the anchor has been clicked on/selected need only carry the value of the P pointer. Note 
that a P pointer can also be used to identify the elements for other control events such as 
an input field or form submission button. 

25 Similarly, OBML provides support for the folders that are the output of the 

normalizer through the use of an "x" pointer attribute. The presence of this X pointer 
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indicates to an object aware browser that an element is an object representing a group of 
child elements and that those children can be requested from the server. 
For example: 

If the anchor shown above was identified as a folder title by the normalizes it would be 

5 represented in OBML as 

<ap="1234" x="1234">Kings beat Wings 2-1, end 14-game playoff skid</a> 
As with the use of the P pointer, events between the browser components 
requesting or delivering the content for expansion of the folder identify the element using 

the X pointer value only. 
10 Note that an element can have a P pointer alone, an X pointer alone or both 

attributes together. 

In the exemplary embodiment, the event translator can provide an interface to a 
WAP gateway and translates events in the following manner, an HTTP GET request for a 
URL of the format p + digits where digits is a number, (e.g. pi 74) is translated to an 
15 "onclick" event targeted at DOM node 174, an HTTP GET request for a URL of the 
format x + digits where digits is a number, (e.g. xl74) is translated to an "expand" event 
targeted at DOM node 174, an HTTP POST request for a URL of the format s + digits 
where digits is a number, (e.g. sl74) is translated to a "submit" event targeted at DOM 
node 174, an HTTP POST request containing postdata name value pairs in the format n + 
20 digits = somevalue (e.g. n323 = foo) is translated to an "onblurchange" event targeted at 
DOM node 323 with value "foo". 

An HTTP POST request containing postdata name value pairs in the format 
somename = n + digits (e.g. myName = n323) is translated to an "onblurchange" event 
targeted at DOM node 323 with value " 1 ". 
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In another embodiment, XML documents or other documents may also originate 

from the electronic device 104. For example, a user may scan a product bar code with a 

electronic device 1 04 to produce a document with a client application on the electronic 

device 104, and send the document via the gateway cluster 18 to an e-commerce 

5 transaction server for processing. 

FIG. 13 further illustrates the process of the distributed browser 108 of FIG. 1 by 

showing a screen shot 300 of an exemplary web page (www.yahoo.com) on both a 

standard PC-based desktop browser (e.g., Microsoft's Internet Explorer) and a screen shot 

304 on the RIM 857 electronic device. To view the yahoo.com web page on a PC-based 

10 desktop browser, a user might use a mouse and/or keyboard to enter the Universal 

Resource Locator (URL) that identifies the page. 

The same user can enter the URL in the RIM device to retrieve the same 

information as shown on the screen shot 300. However, the screen size of the RIM 

device is smaller than that of a typical computer screen of a desktop computer. To 

15 accommodate the RIM screen size, the information is displayed such that the important 

information is displayed first. In this example, Personal email, Departments, Stores, 

Features, Arts & Humanities, Business & Economy are displayed first. The user can then 

appropriately navigate through the rest of the Web site using events such as by clicking, 

loading, changing, etc. In this example, the Business & Economy folder was expanded to 

20 the more information relating to the Business & Economy section, described more below. 

Upon receipt of the event from the RIM device, the server browser proceeds to 

perform the request. The user agent retrieves the information corresponding with the 

URL and appropriately forwards the bit stream to the QDOM. The QDOM then utilizes 

the QDOM to transform the data content into a DOM tree and forwards this tree to the 

25 normalizes The norinalizer (automatic, markup assisted and/or template) creates folders 
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of content, typically by utilizing the characteristics of font, font size, and font color to 

determine the weight of a text node. In general, the titles of the folders are sent to the 

electronic device 304 first. In some instances, however, folder content can be sent down 

to the electronic device with the folder titles. This can occur based on a request by the 

5 user or through a determination by the serializer that the content is sufficiently small to be 

sent in the initial load. 

In this example, the automatic normalizer identifies elements that are of higher 

importance or visibility on the desktop display and uses them as folder titles. Elements 

identified by the normalizer are bold font items (e.g. "My Yahoo!" and "Auctions"), table 

10 headings (e.g. "Departments") and larger font items (e.g. "Business & Economy"). A 

folder title can be derived from both ordinary text (e.g. "Departments") or hyperlinks (e.g. 

"Business & Economy"). In the latter case, the link property is preserved on the device. 

For example, assume the user has selected "Business & Economy" and requested 

an expansion of the folder. The electronic device 304 may already contain the content for 

15 this folder cached in the micro-gateway (FIG. 4), in which case it can display it 

immediately as shown. If the content is not cached on the electronic device 304, 

however, a request is sent to the session manager where the entire DOM is cached. The 

content of the folder being expanded is extracted by the serializer and sent to the 

electronic device where it can then be displayed. It should be noted that the normalizer is 

20 not restricted to a single level of folders but will produce an appropriate level of nested 

folders depending on the nature of the original content. 

In accordance with the present embodiments, the server browser interacts with the 

network content and performs the primary functions unique to this architecture such as 

automatic translations, object based browsing, and object based personalization, hi 

25 addition, the architecture uses XML as the protocol to exchange information between the 
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various systems. Furthermore, the media managers can support instant messaging 
capabilities between desktop browsers and multiple electronic devices. Thus, the data is 
appropriately sent to the electronic device. Furthermore, the user is allowed to navigate 
through the Web site. 

The normalizer also reduces the data content sent to the device by allowing the 
user to browse only the content of interest. It can achieve this by partitioning the web 
page content into expandable objects. The partitioning of content is achieved by a 
normalization process in which normalization rules are applied to the markup language 
tags, such as HTML tags. This feature enables the user to essentially walk a document 
tree and only query for content of interest. 

Some tables which are small enough for an appliance may be sent directly to the 
appliance. These simple tables can be displayed as a table directly on the screen of the 
appliance. The default normalization for a table extracts the content of the table into an 
expandable object-based structure. Simple data type tables should be displayed on the 
device using a table control. Tables used for displaying for formatting or complex data 
(nested information, multiple fonts, mixed information such as text combined with links 
in the one cell, etc.) are not required. Limited support for merged cells in heading rows is 
required. 

Additionally, a user may wish to see the entire contents of a Web site without 
utilizing the expandable object architecture. Therefore, the user can support a "Load All" 
of a Web site, which can result in the full content tree of the Web site being sent to the 
device. In this mode, there will be no expandable objects, however the normalization can 
utilize white-space horizontal tabs to display the parent-child relationship. 

The server browser can have a minimum character, threshold used to determine if 

the children under a parent are small enough to send on a load. The server browser 
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preferably has a maximum children threshold used to determine if the number of 
children under a parent is small enough to send on a load. If the maximum character 
threshold is not exceeded and the maximum children threshold is not exceeded, the 
children will be sent in the load. The server browser preferably has an inline threshold 

5 expansion parameter in which horizontal tabs will be used to show the parent-child 
relationship rather than expandable objects. 

In addition, the user can utilize a find function on the electronic device. The find 
function can send a request to the server browser for a find to be performed on the page 
with a user input string. Options for loading a page and their effect on the content is 

10 specified in the following table. 





Threshold Exceeded 


Threshold Not 
Exceeded/Threshold 
Inline On 


Threshold Not 
Exceeded/Threshold 
Inline Off 


Load All/ No 
Tables 


Thresholding has no effect. 
All content will be sent 
formatted inline. 


Thresholding has no effect. 
All content will be sent 
formatted inline. 


Thresholding has no 
effect. All content 
will be sent formatted 
inline. 


Load 

Summary/ No 
Tables 


Normalized content will be 
sent formatted as 
expandable objects. 


Children under the 
threshold will be sent 
formatted inline. 


Children under the 
threshold will be sent 
formatted as 
expandable objects. 


Load All/ with 
Tables 


Thresholding has no effect. 
All content will be sent 
formatted Inline except for 
tables. 


Thresholding has no effect. 
All content will be sent 
formatted Inline except for 
tables. 


Thresholding has no 
effect. All content 
will be sent formatted 
Inline except for 
tables. 


Load 

Summary/ 
with Tables 


Normalized content will be 
sent formatted as 
expandable objects, except 
for tables. 


Children under the 
threshold will be sent 
formatted Inline. Tables 
will be sent as is. 


Children under the 
threshold will be sent 
formatted as 
expandable objects. 
Tables will be sent as 
is. 



The server browser preferably employs methods to partition content based on user 
profile characteristics. These characteristics could be keywords or usage statistics. The 
15 data content sent to the electronic device may need to be adapted to a specific markup 
language or device dependent requirements (e.g. display size, color capability etc). The 
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protocol and data content sent to the electronic device is preferably compressed and 
optimized to reduce bandwidth usage and cost to the user! 

User authentication and secure communication is preferred by certain web sites 
for private end-to-end communication (from the Internet to the electronic device). This 
secure communication and authentication is accomplished by many mechanisms such as, 
SSL and HTTP Authentication. HTTP Basic Access Authentication scheme is a method 
of user authentication, by passing a user name and password back to a web server. Basic 
Authentication does not encrypt the username and password back to the web server. 

The server browser preferably supports HTTP 1.1 Basic Access Authentication. 
The Device shall have the ability to allow the user to enter the username and password for 
authentication. The SSL Protocol preferably provides privacy and reliability between at 
least two electronic devices. The protocol is composed of two layers. At the lowest 
level, layered on top of some reliable transport protocol (e.g., TCP, is the SSL Record 
Protocol. 

The SSL Record Protocol can be used for encapsulation of various higher level 
protocols. One such encapsulated protocol, the SSL Handshake Protocol, allows the 
server and client to authenticate each other and to negotiate an encryption algorithm and 
cryptographic keys before the application protocol transmits or receives its first byte of 
data. One advantage of SSL is that it is application protocol independent. A higher level 
protocol can layer on top of the SSL Protocol Transparently." The Transport Layer 
Security ("TLS") protocol is a successor to SSLv3. It is an IETF RFC rather than a 
defacto industry standard. The server browser preferably supports SSL version 3.0 or 
later. 

The present embodiments, described herein as exemplary embodiments, provide a 

unique approach to mobilizing critical enterprise content and applications without 
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customization. By transforming and adapting data content in real-time, dynamic 

information that is organized particularly for small-screened, wireless devices can be 

delivered. The present embodiments optimize and organize data content such as Internet 

content, preferably eliminating the need for custom programming or "mirrored 11 Web sites 

5 in non-traditional markup languages such as WML, HDML, C-HTML or XML. Markup 

languages such as HTML, JavaScript and WML content can be read and transform the 

existing content into either XML or WML to adapt to the ergonomics of handheld 

devices, so no additional development costs are incurred. 

It should be understood that the programs, processes, methods and systems 

10 described herein are not related or limited to any particular type of computer or network 

system (hardware or software), unless indicated otherwise. Various types of general 

purpose or specialized computer systems may be used with or perform operations in 

accordance with the teachings described herein. 

In view of the wide variety of embodiments to which the principles of the present 

15 invention can be applied, it should be understood that the illustrated embodiments are 

exemplary only, and should not be taken as limiting the scope of the present invention. 

For example, the steps of the flow diagrams may be taken in sequences other than those 

described, and more or fewer elements may be used in the block diagrams. While various 

elements of the preferred embodiments have been described as being implemented in 

20 software, in other embodiments in hardware or firmware implementations may 

alternatively be .used, and vice-versa. 

It will be apparent to those of ordinary skill in the art that methods involved in the 

system and method for compressing and decompressing a binary code image may be 

embodied in a computer program product that includes a computer usable medium. For 

25 example, such as, a computer usable medium can include a readable memory device, such 
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as a hard drive device, CD-ROM, a DVD-ROM, or a computer diskette, having 
computer readable program code segments stored thereon. The computer readable 
medium can also include a communications or transmission medium, such as, a bus or a 
communication link, either optical, wired or wireless having program code segments 
5 carried thereon as digital or analog data signals. ' 

The claims should not be read as limited to the described order or elements unless 
stated to that effect. Therefore, all embodiments that come within the scope and spirit of 
the following claims and equivalents thereto are claimed as the invention. 
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What is claimed is: 

1. A system for normalizing information content, the system comprising: 
a template normalizer for matching and applying a template to the 
information content; and 
5 an automatic normalizer for folderizing the information content; 

wherein the template normalizer attempts to match a template to the 
information content, and if not, the automatic normalizer folderizes the 
information content to produce a normalized information content. 

10 2. The system of claim 1 wherein the template normalizer recognizes patterns in 

the information content, and wherein the template normalizer dynamically changes the 
information content to match the template. 

3. The system of claim 2 wherein the template normalizer determines if the 

15 variation in the information content is too great to match to a template, and if so, forwards 
the information content to the automatic normalizer. 

4. The system of claim 1 wherein the template normalizer utilizes regular 
expression pattern matching to the information content. 

20 

5. The system of claim 1 wherein the information content is represented by a 
document object tree, and wherein the template normalizer utilizes regular expression 
pattern matching to the document object tree. 

25 6. The system of claim 1 wherein the automatic normalizer utilizes normalization 

markup embedded in the information content to provide the automatic normalizer with 
specific instructions. 

7. The system of claim 1 wherein the automatic normalizer utilizes meta-tags 
30 embedded in the information content to provide the automatic normalizer with at least 
one specific instruction. 
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8. The system of claim 7 wherein the specific instruction is to create a folder 
containing a portion of the information content. 

9. The system of claim 7 wherein the specific instruction is to trigger markup 
5 based normalization. 

10. The system of claim 1 wherein the template normalizer utilizes normalization 
markup embedded in the information content to provide the template noimalizer with at 
least one specific instruction. 

10 

11. The system of claim 10 wherein the specific instruction is to trigger markup 
based normalization. 

12. The system of claim 1 wherein the normalization markup does not affect the 
15 page for display by a PC-based browser that utilizes hypertext markup language (HTML). 

13. The system of claim 1 wherein the information content is in the form of a 
document object model (DOM). 

20 14. The system of claim 1 wherein the information content is in the form of a 

document object tree. 

15. The system of claim 1 further comprising: 

a QDOM for generating a document object tree, wherein the document 
25 object tree is represented by a mutable object. 

16. A system for normalizing a document tree representation, the system 
comprising: 

an automatic normalizer for applying pattern recognition and weighting 
30 heuristics on the document tree to produce a normalized document tree. 
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17. The system of claim 16 wherein the automatic normalizer comprises a 
markup assisted normalizer for processing normalization markup in the document tree to 
produce the normalized document tree. 

5 18. The system of claim 17 wherein the normalization markup does not affect a 

page for display by a PC-based browser that utilizes hypertext markup language 
(HTML). 

19. The system of claim 16 wherein the normalized document tree represents a 
10 hierarchical representation of information in the document tree. 

20. A system for normalizing a document tree representation, the system 
comprising: 

a template normalizer for matching a document tree to a template tree and 
15 applying changes to the document tree to produce a normalized document tree. 

21 . The system of claim 20 wherein the template normalizer determines if the 
document tree matches the template tree, and if not, forwards the document tree to an 
automatic normalizer. 

20 

22. The system of claim 20 wherein the template normalizer utilizes regular 
expression pattern matching to match the template tree to a document tree. 

23. A method for normalizing information content, the method comprises: 
25 matching and applying a template to the information content, and if 

unsuccessful: 

determining if the information content contains normalization 
markup, and if so: 

utilizing normalization markup in the information content to 
30 normalize the information content. 



24. The method of claim 23 further comprises: 
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determining if the information content contains normalization markup, and if not: 

applying pattern recognition and weighting heuristics on the 
information content to normalize the information content. 

5 

25. The method of claim 23 further comprises: 

recognizing patterns in the information content, wherein the template 
normalizer dynamically changes the information content to match the template. 

10 26. The method of claim 23 further comprises: 

determining if a variation in the information content is too great to match 
the template, and if so: 

determining if the information content contains normalization 
markup. 

15 

27. A method for automatically normalizing a document tree, the method 
comprises: 

detemiining node weighting criteria; 

weighting nodes in the document tree according to the determined criteria; 

20 and 

determining parent-child relationships between the weighted nodes based 
on the weighted nodes to produce a normalized document tree. 

28. The method of 27 further comprises: 
25 weighting nodes in a table; and 

attempting to match the table to a predefined pattern of weights, and if 
successful: 

extracting data in response to the predefined pattern. 

30 29. The method of 28 further comprises: 

attempting to match the table to a predefined pattern of weights, and if 
unsuccessful: 

extracting data according to the weighted nodes. 
56 
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30. The method of claim 27 further comprises: 

applying changes to the document tree according to a normalization markup comprising 

dropping nodes, moving nodes, partitioning nodes into folders, and calling user defined 
5 formatting rules on the nodes. 

31. A method for generating a document object tree, the method comprises: 

receiving data; and 

storing information relating to the data into a plurality of arrays; 
10 wherein the plurality of arrays utilize re-usable buffers, and wherein the 

stored information describes the document object tree and tree dependencies as a 
mutable object. 

32. The method of claim 31 further comprises: 

15 transforming the document object tree, wherein the transformed document object tree is 

represent by the single mutable object. 

33. The method of claim 31 further comprises: 

adding an array to the plurality of arrays as the received data grows in size. 

20 

34. The method of claim 3 1 wherein the plurality of arrays are used to hold 
values that represent properties of a node of the document object tree. 

35. The method of claim 31 further comprises: 

25 referencing a re-usable content buffer that contains data; 

wherein the plurality of arrays store start and end positions of data that 
reference the data stored in the re-usable content buffer. 

36. The method of claim 3 1 wherein the plurality of arrays contain values 

30 associated with nodes of the data, and wherein operations on the nodes can be" carried out 
by utilizing the value as referenced to the affected nodes. 
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37. The method of claim 31 further comprises: 

normalizing the document object tree model by a template normalizer for 
applying templates to the document object tree. 

5 

38. The method of claim 3 1 further comprises: 

normalizing the document object tree model by an automatic normalizer 
for applying pattern recognition and weighting heuristics on the document tree to 
produce a normalized document tree.. 

10 

39. A method for comparing a document tree against a template tree, the method 
further comprises: 

matching the document tree by utilizing a template markup language 
comprising regular expression; and 
15 applying changes to the document tree according to the template markup 

language. 

40. The method of claim 39 wherein the document tree is represented by a 
plurality of nodes, and wherein the template markup language comprises dropping at least 

20 one of the plurality of nodes, moving at least one of the plurality of nodes, partitioning at 
least one of the plurality of nodes into folders, and calling user defined formatting rules 
on at least one of the plurality of nodes. 
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